UM82C206 


INTEGRATED PERIPHERAL CONTROLLER 


PRELIMINARY 


FEATURES 
B Fully compatible with PC/AT architecture 


B Fully compatible with 8237 DMA controller, 
8259 interrupt controller, 8254 
timer/counter, and 146818 real time clock 


B® Provides 7 DMA channels, 13 interrupt 
request channels, 2 timer/counter channels, 
and a real time clock 


®@ Built in 74LS612 memory mapper for DMA 
page address 


BH Provides 114 bytes of CMOS RAM memory 


GENERAL DESCRIPTION 


The UM82C206 Integrated Peripheral 
Controller includes two 8237 DMA controllers, 
one 8254 
timer/counter, one MC146818 compatible real 
time clock,an additional 64 bytes CMOS RAM, 
one 74LS612 memory mapper, and some top 


two 8259 interrupt controllers, 


level decoder/configuration logic circuits. It 1s 
a single chip integration of all main 
peripheral parts attached to the X bus of 
PC/AT architecture. While providing full 
compatibility with PC/AT architecture, the 
UM82C206 also offers some enhanced features 


— 8 MHz DMA clock with programmable 
internal divider for 4 MHz operation 


i 16M byte DMA address space 


@ Programmable wait states for the DMA 
cycle 


i Reduced recovery time (120ns) between I/O 
operations 


and improved speed performance. These 
include an additional 64 bytes of user 
definable CMOS RAM in real time clock and 
drastically reduced recovery time for the 8237, 
8259 and 8254. Programmable wait state option 
is provided for the DMA cycles and CPU [/O 
cycles accessing this chip. This chip also 
provides programmable 8 or 4 MHz DMA 
clock selection. The UM82C206 is implemented 
using advanced 1.5u CMOS design technology 
and is packaged in an 84-pin PLCC. 
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Figure 1. Pin Assignment 
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Figure 2. UM82C206 Block Diagram 
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Oume UM82C206 


PIN DESCRIPTION 


Pin No. Symbol pio | Description 


Clock and Control 


vA SYSCLK CLOCK INPUT is used to generate the timing signals for 
DMA operation. This pin can be driven to 10 MHz frequency. 
The internal clock used for DMA operation is either 
SYSCLK or SYSCLK/2 which is a programmable option. 

1c OSCI ] OSCILLATOR INPUT is used to generate the time base for 
the time function of real time clock. External square waves 
of 32.768 KHz may be connected to this pin. 


RESET RESET is an active high input which affects the following 
registers: 
DMA controller: Clears the command, status, request, 
temporary registers, byte pointer flip flop. Sets the mask 
register. Following reset, DMA controller is in the idle state. 
INTERRUPT controller: Clears the edge sense circuit, mask 
registers, all ICW4 functions. IRQO is assigned the highest 
priority. Slave address is set to 7. Special mask mode 1s dis- 
able and status read is set to IRR. 


18 
68 IOCHRDY| 1/0 1/0 CHANNEL READY is a bidirectional pin. 


In the input mode, it is used to extend the memory read or 
write pulses for the DMA controller to access slow memories 
or I/O devices. It must satisfy setup and hold times with 
respect to the DMA internal clock 1n order to work reliably. 
A low on IOCHRDY causes the internal DMA ready signal 
to go low asynchronously. When IOCHRDY goes high, one 
DMA clock cycle will elapse before internal DMA ready 
signal goes high. 


In the output mode, it is an open drain output and provides 
an active low output whenever a UM82C206 internal 
register is accessed. It will remain low for a 
pre-programmed number of DMA internal clock cycles (as 
controlled by bits 7 and 6 of UM82C206 configuration 
register) and then goes high. In this way, IOCHRDY can 
insert wait states (as counted by DMA internal clock cycles) 
when CPU accesses the UM82C206 internal registers. This 
pin must be pulled up by an external resistor. In a PC/AT 
architecture based design this pin should be wire-ORed to 
the PC/AT's IOCHRDY signal. 


Pin No. Symbol Rion 


2431 | XDT-XDO 
39-43 XA8-XA0 | I/O 
34 XA9 ] 


UM82C206 


Description 


X DATA BUS are 3-state bidirectional pins which are 
connected to the XD bus in PC/AT architecture design. 


During CPU I/O read cycles, these they are output pins to 
read out the contents of UM82C206 internal registers. 


During CPU I/O write cycles, these are input pins to let 
CPU program the contents of UM82C206 internal registers. 


During DMA cycles, the most significant 8 bits of the 
address are ouput onto these pins to be strobed into an 
external latch by ADSTB8 or ADSTBIJ6. During DMA 
memory-to-memory transfers, data from the memory comes 
into the DMA controller via these pins and stores in the 
internal temporary register during read from the memory 
partial cycle. In the write to memory partial cycle, the data 
Stored in the temporary register will output via these pins 
again and write into the new memory location. 


During the interrupt acknowledge cycle, the interrupt 
controllers output the interrupt vector byte via these pins. 
These pins are also used as the multiplexed address/data 
bus for the real time clock and the CMOS RAM accesses. 


X ADDRESS BUS are connected to the XA bus in PC/AT 
architecture design. XA8-XA0O pins are bidirectional pins. 
XAQ is an input only pin. 


During CPU I/O accesses to the UM82C206, XA9-XAO are 
used to address configuration register and the internal 
registers of 8237s, 8259s, 8254, MC146818, CMOS RAM, 
74LS612. 


During a CPU cycle, XA3-XA0 pins are used by the CPU to 
address the registers of the DMA controller corresponding 
to DMA channels 0-3. XA4-XA1 pins are used by the CPU to 
address the registers of the DMA controller corresponding 
to DMA channels 5-7. 


During a DMA cycle, XA7-XA0 pins are outputs and carry 
address information for DMA channels 0-3. XA8-XA1 pins 
are outputs and carry address’ information for DMA 
channels 5-7. 
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Pin No. Symbol wo Description 


o4 


a2 


61 


62 


73 


69 


: 
- 


DMAMEMR®* 


“_ a 


X I/O READ isa bidirectional active low 3-state pin. In a non 
DMA or non interrupt cycle, it is an input control signal 
used by the CPU to read the UM82C206 internal registers. In 
an active DMA cycle, it is an output control signal used by 
the DMA controller to access data from a peripheral during 
a DMA write memory transfer. 


X I/O WRITE is a bidirectional active low 3 state pin. Ina 
non DMA or non interrupt cycle, it is an input control signal 
used by the CPU to write the UM82C206 internal registers. 
In an active DMA cycle, it is an output control signal used 
by the DMA controller to write data toa peripheral during a 
DMA read memory transfer. 


DMA MEMORY READ 1s an active low 3-state output pin 
used to access data from the selected memory location 
during DMA read memory or memory-to- memory transfer. 


DMA MEMORY WRITE 1s an active low 3-state output pin 
used to write data to the selected memory location during 
DMA write memory or memory-to- memory transfer. 


HOLD ACKNOWLEDGE 1 is an active high signal from the 
UM82C211C to indicate that the CPU has relinquished 
control of the system busses. 


HOLD REQUEST is an active high output to the 
UM82C211C to request control of the system bus. When a 
DREQ occurs and the corresponding mask bit 1s clear, or a 
software DMA request is made, the DMA controller issues 
HRQ to the UM82C211C. After CPU releases the system bus, 
the UM82C211C then issues a HLDA] back to the UM82C206 
if DMA has been permitted to control the system bus. 


DMA REQUEST is an asynchronous DMA channel request 
input for each DMA channel. In fixed priority, DREQO has 
the highest priority and DREQ7 has the lowest priority. A 
periphal device will activate a DREQ line if it needs a DMA 
service. DACK will acknowledge the recognition of DREQ 
request. DREQ must be maintained until the corresponding 
DACK goes active. DREQ will not be recognized while the 
DMA clock js stopped. Unused DREQ inputs should be kept 
inactive and the corresponding mask bit should be set to 
avoid an undesired DMA function. Polarity of DREQ is 
programmable. Reset initializes these lines to active high. 
DREQO-DREQ3 support 8-bit transfers between 8-bit I/O 
device and 8 or 16-bit system memory. DREQS-DREQ7 
support 16-bit transfers between 16-bit I/O device and 16-bit 
system memory. DREQ4 1s not externally available and 1s 
used to cascade DREQO-DREQ3. 
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Pin No. 


48-51 


07-55 


66 


65 


63 


64 


| Symbol [NO 


ADSTBI16 


AEN8* 
AEN16* 


: ‘ 
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Descnption 


TERMINAL COUNT is an active high signal. It indicates 
the completion of DMA services. A pulse is generated by the 
DMA controller when terminal count for any channel is 
reached except for channel 0 in memory-to-memory transfer 
mode. During memory-to-memory transfer terminal count 
will be generated when the terminal count for channel 1 
occurs. When a TC pulse occurs, the DMA controller will 
terminate the service, and if auto initialize is enabled, the 
base registers will be written to the current registers of 
that channel. The mask bit and TC bit in the status register 
will be set for the currently active channel unless the 
channel is programmed for auto-initialization. In that case, 
the mask bit remains clear. 


DMA ACKNOWLEDGE is used to notify the individual 
peripherals when one has been granted a DMA cycle 
Because these signals are used internally for cascading the 
DMA channels and for DMA page register selection, they 
must be programmed to active low and cannot be changed. 
Reset initializes them to active low. 


ADDRESS STROBE 8 is an active high output. It is used to 
latch the upper address byte XA8-XA15 for 8-bit peripheral 
devices. During DMA block transfers, ADSTB8 will only be 
issued when the upper address byte must be updated, thus 
speeding transfer through elimination of Sl] states of DMA 
cycles. ADSTBS8 is active for DMA channels 0-3. 


ADDRESS STROBE 16 is an active high output. It is used to 
latch the upper address byte XA9-XA16 for 16-bit peripheral 
devices. During DMA block transfers, ADSTBI6 will only be 
issued when the upper address byte must be updated, thus 
speeding transfer through elimination of Sl] states of DMA 
cycles. ADSTBI6 is active for DMA channels 5-7. 


ADDRESS ENABLE 8 is an active low output. It is used to 
enable the latch of the upper address byte XA8-XA15 for 
8-bit peripheral devices. It is inactive when external bus 
master controls the system bus. AEN8* is active for DMA 
channels 0-3. 


ADDRESS ENABLE 16 is an active low output. It is used to 
enable the latch of the upper address byte XA9-XA16 for 
16-bit peripheral devices. It is inactive when external bus 
master controls the system bus. AENI6* is active for DMA 
channels 5-7. 
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Pin No. Symbol no | Description 
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MODULE SELECT ENABLE its a two purpose input. When 
high, it enables the chip select function on one of the modules 
of UM82C206 for the CPU programming functions. When low, 
the UM82C206 is essentially disconnected from the system bus 
and is capable of performing an active DMA or an interrupt 
cycle. In a PC/AT architecture design, it is tied to ACK® 
signal of main board. 


A23-Al7 and XA16 are 3-state output pins. A23- Al7 are the 
upper 7 bits of the DMA page register. XA16 is the least 
significant bit of the DMA page register and is used for DMA 
transfers for 8-bit peripheral devices only. XA16 is not used 
for 16-bit DMA transfers as XAl16-XA9 being provided by 
demultiplexing the data bus. 


INTERRUPT REQUESTS are asynchronous inputs. When 
8259 is operating in edge triggered mode, an interrupt request 
is executed by raising an IRQ input low to high and holding it 
high until it is acknowledged by CPU. 

When 8259 is operating in level triggered mode, an interrupt 
request is executed by raising an IRQ input high and holding 
it high until it is ack nowledged by CPU. 


INTERRUPT ACKNOWLEDGE is an active low input. It is 
used to enable the interrupt controllers to output the vector 


-data on to the data bus by an interrupt acknowledge sequence 


from the CPU. 


INTERRUPT REQUEST is an active high output pin. It is 
connected to the CPU's interrupt pin and is used to interrupt 
the CPU when an interrupt request occurs. 


TIMER CLOCK is an input clock for 8254 counter 0, counter 1 
and counter 2. In PC/AT architecture design, it is 
approximately 1.19 MHz. 


GATE 2 is a gate input for 8254 counter 2. In PC/AT 
architecture design, the counter 2 is used for tone generation 
for speaker. It is driven by bit 0 of 1/O port 61h. 


OUT 1 is an output of 8254 counter 1. In PC/AT architecture 
design, the counter 1 is programmed as a rate generator to 
produce a 15 usec period signal for DRAM refresh. 


OUT 2 is an output of 8254 counter 2. In PC/AT architecture 
design, counter 2 is used for tone generation for speaker. 


Pin No. 


ae 


14 


ie 


32,79 


1293) 
74 


15 PSRSTB* : 
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Description 


ADDRESS STROBE 1s an active high input. It is pulsed by 
UM82C211C when CPU accesses the real time clock or 
CMOS RAM of the UM82C206. The falling edge of this pulse 
latches the address from the XD bus. 


POWER SUPPLY STROBE is an active low input. It is used 
to establish the condition of the control registers of real 
time clock when power is applied to the device. In PC/AT 
architecture design, it should be tied to the battery back-up 
circuit. When PSRSTB* and TEST are both low, the follow- 
ing occurs: 


(a) Periodic Interrupt Enable (PIE) bit is cleared to zero. 

(b) Alarm Interrupt Enable (AIE) bit is cleared to zero. 

(c) Update ended Interrupt Enable (UIE) bit is cleared to 
Zero. 

(d) Update ended Interrupt Flag (UF) bit is cleared to zero. 

(e) Interrupt Request status Flag (IRQF) is cleared to zero. 

(f) Periodic Interrupt Flag (PF) bit is cleared to zero. 

(g) The part is not accessible. 

(h) Alarm interrupt Flag (AF) bit is cleared to zero. 

(1) Square Wave output enable bit is cleared to zero. 


POWER GOOD is an active high input and is connected to 
the power good of the power supply in PC/AT architecture 
design. It must be high for bus cycles in which the CPU 
accesses the real time clock. When it is low, all address, data, 


data strobe and R/W pins are disconnected from the 
processor. 


TEST is an active high input to enable the chip testing for 
production. It should be tied low for normal operation. 


POWER SUPPLY 


GROUND 
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FUNCTIONAL/REGISTER DESCRIPTION 
TOP LEVEL DECODER AND CONFIGURATION REGISTER 


The UM82C206 top level decoder provides 8 
separate enables to various subsystems of the 
device. Table J. contains a truth table for the top 
level decoder. The enabling of the UM82C206 
XD0-XD7 output buffers is also controlled by 
this section. The output buffers are enabled 


Table 1. UM82C206 Internal Decode 


UM82C206 


whenever an enable is generated to an internal 
subsystem and the XIOR* signal is also asserted. 
The decoder is enabled by signals ACK*, XA9, 
XA8. To enable any internal subsystem ACK* 
must be 'l'and both XA9 and XA8 must be 0° 


ACK XAS XA8 XA7 XAG XA5 XA4 XA3 XA2 XAl XAO = ADDRESS SELECTED 
RANGE (HEX) DEVICE 

PO Oe 30520) “0m 020) kee A RO OC0SO0R DMA8 
Oey 20 205 ISOs 0h > 0s =X 020202) INTC] 

1 ORO) 02S Oe Oar Oumar 2X (022-025 CONF IG 

Pe 0 0 Or 0p A000: XK OAD NaS CTC 

lie One O as Reclaeal Sele Omen oO, 0" “31> whorl RTC 

1b FOTO eOe0" (0K ROK XK 08050 DMAPAGE 
107 S08 ie O. BO Or Or 0) ako SOA0Z0RI INTC2 
On 305 TS ele 10" ieee kX SOLO-0DF DMA16 

Oy {Xmen Re Ave Ne Aen AA Ae Ape oA DISABLED 
Keeper ue h cdot NieraX alee REN OA hi A DISABLED 
) geet (a) C2) OR Se ds) ns) DISABLED 


QJume 


Configuration Register 


() 
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Index register port : 22H 
Data register port : 23H 
Index : 01H 


Bits Function 


7-6 These bits contain the information of wait states inserted when the CPU accesses the 


registers of UM82C206. Wait states are counted as SYSCLK clock cycles and are not affected 
by the DMA clock selection. 


6 | Register [1/0 R/W wait states 


] 
2 
3 
4 


(default) 


9-4 These bits contain the information of wait states inserted in 16 bit DMA cycles. Further 
control of the DMA cycle length is available through the use of the IOCHRDY pin of the 


UM82C206. During DMA cycle this pin is used as an input to the wait state generation logic 
to extend the cycle if necessary. 


5 4116 bit DMA wait states 


0 0 1 (default) 
Oat Z 
1 0 3 
Le] 4 


3-2 These bits contain the information of wait states inserted in 8 bit DMA cycles. Further 
control of the DMA cycle length is available through the use of the IOCHRDY pin of the 


UM82C206. During DMA cycle this pin is used as an input to the wait state generation logic 
to extend the cycle if necessary. 


2/18 bit DMA wait states 


0 0 1 (default) 
0 1 2 
1 0 3 
ie 4 
1 EMR bit enables the early DMAMEMR?’ function. In IBM PC/AT design DMAMEMR* is 


delayed one clock cycle later than XMEMR*. If set to 1, it will start DMAMEMR*% at the same 
time as XMEMR* If set to 0, it will start DMAMEMR* as an IBM PC/AT design (default). 


0 CLK bit selects the DMA clock. If this bit set to 0, the SYSCLK input is divided by two and 1s 
used to drive both the 8-bit and 16-bit DMA subsystems (default). If this bit 1s set to 1, the 
SYSCLK will directly drive the DMA subsystems. Whenever the state of this bit 1s changed, 


an internal synchronizer controls the actual switching of the clock to prevent a short clock 
pulse from causing a DMA malfunction 
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DMA SUBSYSTEM 


The UM82C206 contains two 8237 DMA 
controllers. Each controller is a four channel 
DMA device which will generate the memory 
addresses and control signals necessary to 
transfer data between a peripheral device and 
memory directly. The two DMA controllers are 
internally cascaded to provide four DMA 
channels for transfers to 8-bit peripherals 
(DMA8), and three channels for transfers to 
16-bit peripherals (DMA16). The channel 0 of 


UM82C206 


DMA\I16 provides the cascade interconnection of 
the two DMA devices, thereby maintaining PC/ 
AT compatibility. Hereinafter, the description 
of the DMA subsystem pertains to both DMA8 
and DMAI6 unless otherwise noted. 


DMA I/O Address Map 


The I/O address map of the DMA subsystem of 
UM82C206 is listed in Table 2. The mapping is 
fully compatible with PC/AT architecture. 


Table 2. DMA Subsystem I/O Address Map 


ADDRESS 


001H O0C2H Ona 0 
Orel l 
1 0 0 
1 0 l 
002H 0C4H 0 1 0 
Oe ] 
1 O 0 
E*O 1 
003H OC6H 01 0 
0 1 1 
10 0 
i 6) i 
004H O0C8H 01 0 
01 ] 
1 0 0 
ibe 8 ] 
005H OCAH Ou 0 
01 l 
1 0 0 
1 0 1 
006H 


0CCH 0 1 0 
0} 1 
1 0 0 
1 0 l 


REGISTER 
FUNCTION 


Read channel 0 current address low byte 

Read channel 0 current address high byte 

Write channel 0 base and current address low byte 
Write channel 0 base and current address high byte 


Read channel 0 current word count low byte 

Read channel 0 current word count high byte 

Write channel 0 base and current word count low byte 
Write channel 0 base and current word count high byte 


Read channel 1] current address low byte 

Read channel 1 current address high byte 

Write channel 1 base and current address low byte 
Write channel ] base and current address high byte 


Read channel 1 current word count low byte 

Read channel 1 current word count high byte 

Write channel 1 base and current word count low byte 
Write channel 1 base and current word count high byte 


Read channel 2 current address low byte 

Read channel 2 current address high byte 

Write channel 2 base and current address low byte 
Write channel 2 base and current address high byte 


Read channel 2 current word count low byte 

Read channel 2 current word count high byte 

Write channel 2 base and current word count low byte 
Write channel 2 base and current word count high byte 


Read channel 3 current address low byte 

Read channel 3 current address high byte 

Write channel 3 base and current address low byte 
Write channel 3 base and current address high byte 
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DMA8 DMA16} XIOR* XIOW* | POINTER FUNCTION 
007H OCEH Onl 0 Read channel 3 current word count low byte 
01 if Read channel 3 current word count high byte 
1 0 0 Write channel 3 base and current word count low byte 
1 0 1 Write channel 3 base and current word count high byte 
008H ODO0OH 0 1 X Read status register 
Pc) X Write command register 
0O9II OD2H Oa X Read DMA request register 
1 0 X Write DMA request register 
OOAH OD4H 0 1 X Read command register 
10 xX Write single bit DMA request mask register 
0OOBH OD6H 01 xX Read mode register 
10 X Write mode register 
00CH OD8H 01 X Set byte pointer flip/flop 
1 0 X Clear byte pointer flip/flop 
0OODH ODAH 0 1 xX Read temporary register 
1 X Master clear 
O0OEH ODCH 0] X Clear mode register counter 
10 xX Clear all DMA request mask register bits 
0OOFH ODEH OF) xX Read all DMA request mask register bits 
Le) X Write all DMA request mask register bits 


DMA Operation 


During normal operation of the UM82C206, the 
DMA subsystem will be in either the idle 
condition, the program condition or the active 
condition. When DMA controller is in the idle 
condition, it only executes the SI idle state 
cycles. The DMA controller will remain in the 
idle condition unless it has been initialized to 
work and one of the DMA request pins has been 
asserted. In that case, the DMA controller will 
exit the idle condition and enter the active 
condition. The DMA controller will also exit the 
idle condition and enter the program condition 
when CPU attempts to access its internal regis- 
ters. 


Idle Condition 


When no peripherals request service, the DMA 
subsystem will enter the idle condition and 
perform only the SI idle states. During this time 
the UM 82C206 will sample the DREQ input pins 
every clock cycle to determine if any peripheral 
is requesting a DMA service. The internal select 
from the top level decoder and HLDAI input pin 
will also sample at the same time to determine if 
the CPU is attempting to access the internal 
registers. With either of the above two 
conditions satisfied, the DMA subsystem will 
exit the idle condition and enter the program 
condition or the active condition. Note that the 
program condition has priority over the active 
condition since a CPU cycle has already started 
before DMA has been granted use of the bus. 


Program Condition 


The DMA subsystem will enter the program 
condition whenever HLDAI input pin is inactive 
and an internal select from top level decoder is 
active. During this time, the address lines 
XA0-XA3 become inputs 1f DMA8 is selected, or 
XA1-XA4 become inputs if DMA16 is selected. 
These address inputs are used to decode the 
DMA controller registers which are to be 
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accessed. The XIOR* and XIOW* are used to 
select and time the CPU reads or writes. When 
DMAI6 is selected, the XA0 1s not used to decode 
and is ignored. Due to the large number and size 
of the internal registers of the DMA subsystem, 
an internal byte pointer flip/flop is used to 
supplement the addressing of the 16-bit word 
count and address registers. This byte pointer is 
used to determine the upper or lower byte of the 
word count and address registers. This byte 
pointer flip/flop 1s cleared by hardware RESET 
or a master clear command. It may also be set or 
cleared by the CPU's 'set byte pointer flip/flop’ 
or clear byte pointer flip/flop' commands. There 
are special commands supported by the DMA 
Subsystem in the program condition. These 
commands do not use the data bus but are 
derived from a set of addresses, the internal 
sclect and XIOR* or XIOW*. These commands 
are listed at the end of table 2. Erratic operation 
of the UM82C206 can occur if a request for 
service occurs on an unmasked DMA channel 
which is being programmed. The channel 
should be masked or the DMA should be 
disabled to prevent the UM82C206 from 
attempting to service a peripheral with a 
channel which is only partially programmed. 


Active Condition 


The DMA subsystem will enter the active 
condition whenever a software request occurs 
or a DMA request occurrs on an unmasked 
channel which has already been programmed. 
When a DREQ occurs and the corresponding 
mask bit is clear, or a software DMA request is 
made, the DMA subsystem issues HRQ to the 
UM82C211C. After CPU releases the system bus, 
the UM82C211C then issues a HLDAI back to 
the UM82C206 if DMA has been permitted to 
control the system bus. After being granted 
control of the bus, the DMA subsystem will then 
begin a DMA transfer cycle. Take DMA read 
cycle as an example. After receiving a DREQ, 


UM82C206 


the UM82C206 will issue a HRQ to the 
UM82C211C. Until a ITLDA1 is returned, the 
DMA subsystem will remain in an idle condi- 
tion. On the next clock cycle the DMA will exit 
idle and enter SO state. During SO the DMA will 
resolve priority and issue DACK on the highest 
priority channel which is requesting service. 
The DMA will then enter Sl state where the 
multiplexed addresses are output and latched. 
The DMA will then enter S2 State where the 
UM82C206 asserts DMAMEMR® command. The 
DMA will then enter S3 state where the 
UM82C206 asserts XIOW* command. The DMA 
will then remain in S3 until the wait state 
counter has expired and IOCHRDY is high. Note 
that at least one additional S3 will occur unless 
compressed timing iS programmed. Once a 
ready condition is detected, the DMA will enter 
S4. where DMAMEMR* and XIOW* are 
deasserted. In compressed mode and demand 
mode, subsequent transfers will begin in S2 
unless the intermediate addresses require 
updating. In these subsequent transfers the 
lower addresses are changed in S2. 


Transfer Modes 


There are four transfer modes supported by the 
DMA. They are single transfer mode, block 
transfer mode, demand transfer mode and 
cascade mode. The DMA can be programmed on 
a channel by channel basis to operate in one of 
these four modes. 


Single Transfer Mode - In this mode the DMA 
will execute only one cycle at a time. DREQ 
must be held active until DACK becomes active 
in order to be recognized. If DREQ is held active 
throughout the single transfer, the _UM82C206 
will deassert HRQ and release the bus to the 
system once the transfer is complete. After 
HLDAI1 has gone inactive the UM82C206 will 
again assert HRQ and execute another transfer 
on the same channel unless a request from a 
higher priority channel has been received. In 
single transfer mode the CPU is ensured of at 
least one full machine cycle execution between 
DMA transfers. Following each transfer the 


word count register is decreased and the 
address register is increased or decrased 
depending on the DEC bit of mode register. 
When the word count decrements from 0000H to 
FFFFH the terminal count bit in the status 
register is set and a pulse is output to TC pin. If 
the autoinitialization is selected, the channel 
will reinitialize itself for the next service. 
Otherwise, the DMA will set the cor_ 
responding DMA request bit mask and suspend 
transferring on that channel. 


Block Transfer Mode - In this mode the DMA 
will begin transfers in response to either a 
DREQ or a software request. If DREQ starts the 
transfers, it need only be held active until 
DACK becomes active. The transfers will con- 
tinue until the word count decrements from 
000011 to FFFFH, at which time TC pin 1s pulsed 
and the terminal count bit of status register is 
set. Again, an autoinitialization will occur at the 
end of the last service if the channel has been 
programmed todo so. 


Demand Transfer Mode - In this mode the DMA 
will begin transfers in response to the assertion 
of DREQ and will continue until either terminal 
count is reached or DREQ becomes inactive. 
This mode is normally used for peripherals 
which have limited buffering capacity. The 
peripheral can initiate a transfer and continue 
until its buffer capacity is exhausted. The 
peripheral may then re-establish service by 
again asserting DREQ. During idle. periods 
between transfers the CPU is released to 
operate and can monitor the operation by 
reading intermediate values from the address 
and word count register. Once DREQ has been 
deasserted, higher priority channels are allowed 
to intervene. Reaching terminal count will 
result in the generation of a pulse on TC pin, the 
setting of the terminal count bit in the status 
register and autoinitialization if programmed to 
do so. 

Cascade Mode - This mode is used to 
interconnect more than one DMA controller, to 
extend the number of DMA channels while 
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preserving the priority chain. In cascade mode 
the master DMA controller does not generate 
address or control signals). The DREQ and 
DACK signals of the master are used to in- 
terface the HRQ and HLDAI signals of the slave 
DMA devices. Once the master has received a 
HLDAI from the CPU in response to a DREQ 
caused by the HRQ from a slave DMA controller, 
the master DMA controller will ignore all in- 
puts except HLDA] from the CPU and DREQ on 
active channel. This prevents conflicts between 
the DMA devices. 


Figure 3. shows the cascade interconnection for 
two levels of DMA devices. Note that channel 0 
of DMAI6 is internally connected for cascade 
mode to DMA8. Additional devices can be 
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cascaded to the available channels in either 
DMA8 or DMAI6 since cascade 1s not limited to 
two levels of DMA controllers. 


When programming cascaded controllers, begin 
with the device which is actually generating 
HRQ to the system (first level device) and then 
proceed to the second level devices. RESET 
causes the DACK* outputs to become active low 
and are placed in the inactive state. To allow the 
internal cascade between DMA8 and DMAI6 to 
function correctly, the active low state of 
DACK* should not be modified. The first level 
devices DMA request mask bits will prevent 
second level cascaded devices from generating 
unwanted hold requests during the initialization 
process. 


OPTIONAL 
8237A 
DMA 
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Transfer Types 

Single transfer mode, block transfer mode and 
demand transfer mode can perform any of the 
three transfer types. These three transfer types 
are read , write and verify transfers. 

Read Transfers - These transfers move data 
from memory to an I/O peripheral by 
generating the memory address and asserting 
DMAMEMR®* and XIOW* during the same 
transfer cycle. 


Write Transfers - These transfers move data 
from an I/O peripheral to memory by 
generating the memory address and asserting 
DMAMEMW* and XIOR* during the same 
transfer cycle. 


Verify Transfers - The verify transfers are 
pseudo transfers. In this type of transfer the 
DMA will operate as in read or write transfers 
by generating HRQ, DACK, memory addresses 
and respond to the terminal count. But it does 
not activate the memory and I/O command 
signals. Since no transfer actually takes place 
IOCHRDY is also ignored during’ verify 
transfers. 


Memory-to-Memory Transfers - In addition to 
the above three transfer types, there is also a 
memory-to-memory transfer which can only be 
used on DMA channel 0 and channel 1. The 
memory-to-memory transfer is used to move a 
block of memory from one location in memory 
to another. DMA channels 0 and 1 may be 
programmed to operate as memory-to-memory 
channels by setting a bit in the DMA command 
register. Once programmed to do so the transfer 
can be started by generating either a software 
or an external request to channel 0. During the 
transfer, channel 0 provides the address for the 
source block during the memory read portion of 
the transfer, channel 1 generates the address for 
the destination block during the memory write 
portion of the same transfer. During the read 
portion transfer, a byte of data is latched in the 
internal temporary register of DMA. The 
contents of this register are then output on the 
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XD0-XD7 output pins during the write portion 
of the transfer and subsequently written to 
memory location. Channel 0 may be pro: 
grammed to maintain the same source address 
on every transfer. This allows the CPU to 
initialize large blocks of memory with the same 
value. The DMA subsystem will continue 
performing transfers until channel 1 reaches 
the terminal count. 


Autoinitialization 


The mode register of each DMA channel 
contains a bit which will cause the channel to 
reinitialize after reaching terminal count. 
During autoinitialization , the base address 
and base word count registers, which were 
originally programmed by the CPU, are 
reloaded into the current address and current 
word count registers. The base registers remain 
unchanged during DMA active cycles and can 
only be changed by the CPU. If the channel has 
been programmed to autoinitialize, the request 
mask bit will remain cleared upon reaching 
terminal count. This allows the DMA to 
continue operation without CPU intervention. In 
memory-to-memory transfers the word count 
registers of both channel 0 and channel 1 must 
be programmed with the same starting value 
for full autoinitialization. 


DREQ Priority 


The UM8&2C206 supports two types of priority 
schemes which are software programmable. 
They are fixed priority and rotating priority. 
Fixed priority assigns priority based on channel 
position. In this method channel 0 1s assigned 
the highest priority and channel 3 is the lowest 
priority. After the recognition of any one 
channel for service, the other channels are 
prevented from interfering with that service 
until it 1s completed. In rotating priority, the 
ordering of priority from channel 0 to channel 3 
iS Maintained but the actual assignment of 
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priority changes. The channel most recently 
serviced will be assigned the lowest priority and 
since the order of priority assignment remains 
fixed, the remaining three channels rotate 
accordingly. The rotating priority assignment 1s 
illustrated in Figure 4. In instances where 
multiple requests occur at the same time, the 


UM82C206 will issue a HRQ but will not freeze 
the priority logic until HLDAI is _ returned. 
Once HLDA] becomes active the priority logic is 
frozen and DACK 1s asserted on the highest 
requesting channel. Priority will not be reevalu- 
ated until HLDAI has been deactivated. 
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Figure 4. Rotating Priority Scheme 


Address Generation 

Eight intermediate bits of the address are 
multiplexed onto the data lines during active 
cycles of the DMA. This reduces the number of 
pins required by the DMA subsystem. During S1l 
state, the intermediate addresses are out- put on 
data lines XD0-XD7. These addresses should be 
externally latched and used to drive the system 
address bus. Since DMA8 is used for &bit 
transfers and DMAI16 is used for 16-bit transfers, 
a l-bit skew occurs in the intermediate 
address fields). DMA8& will therefore output 
addresses A8-Al5 on the data bus at this time 
whereas DMAI16 will output A9-Al16. A separate 
set of latch and enable signals are provided for 
both DMA8 and DMAI16 to accommodate the 
address skew. 


During 8&-bit DMA transfers, in which DAM8 is 


active, the UM82C206 will out- put the lower 
8-bits of address on XA0-XA7. The intermediate 
8-bits of add- ress will be output on XDO0-XD7 
and ADSTB8 will be asserted for one DMA 
clock cycle. The falling edge of ADSTB8 is used 
to latch the intermediate address- es A8-Ald. An 
enable signal, AEN8, issused to control the 
output drivers of the external latch. Al6-A23 are 
also generated at this time from a DMA page 
register in the UM82C206. Note that A16 is 
output on the XA16 pin of the device. 


During 16-bit DMA transfers, in which DAMI6 
is active, the UM82C206 will output the lower 
8-bits of address on XA1-XA8. The intermediate 
8-bits of address A9-Al6 will be output on 
XD0-XD7 and ADSTBI6 will be asserted for one 
DMA clock cycle. The falling edge of ADSTB16 
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is used to latch the in- termediate addresses 
A9-Al6. An enable signal, AIENI16, issued to 
control the output drivers of the external latch. 
A17-A23 are also generated at this time from a 
DMA page register in the UM82C206. Note that 
XAO and XAI16 remain 3-state during 16-bit 
DMA transfers. 

The DMA page registers are a set of 16 8-bit 
registers in the UM82C206 which are used to 
generate the high order addresses during DMA 
cycles. Only 8 of the registers are actually used 
but all 16 were included to maintaim PC/AT 
compatibility. Each DMA channel has a page 
register associated with it with the exception of 
channel 0 of DMA16 which 1s used for internal 
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cascading to DMA8. Assignment of each of 
these registers is shown in Table 3. along with 
its CPU I/O read/write address. 

During demand and block transfers, the 
UM82C206 generates multiple sequen- tial 
transfers. For most of these transfers the 
information in the external address latches will 
remain the same, eliminating the need to be 
relatched. Since the need to update the latches 
occurs only when a carry or borrow from the 
lower 8-bits of the address counter exists, the 
UM82C206 will only update the latch contents 
when necessary. The UM82C206 will therefore 
only execute Sl state when necessary and 
improve the overall system throughput. 


Table 3. DMA Page Register I/O Address Map 


oo 
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DMA8 channel 1 (DACK1) 


DMA8 channel 0 (DACK(O) 


DRAM refresh cycle 
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Compressed Timing 


The DMA subsystem in the UM82C206 can be 
programmed to transfer a word in as few as 2 
DMA clock cycles. Normal transfers require 4 
DMA clock cycles since S3 is executed twice due 
to the one wait state insertion. In systems 
capable of supporting higher throughput, the 
UM82C206 can be programmed to omit one $3 
and assert both commands in S2. S2 begins the 
cycle by generat- ing the address and asserting 
both commands. One S3 cycle is executed and 
the cycle terminates in S4. If compressed timing 
is selected, TC will be output in S2 and Sl cycles 
will be executed as necessary to update the 
address latch. Note that compressed timing 1s 
not allowed for memory-to- memory transfers. 


Register Description 


Current Address Register 


Each DMA channel has a 16-bit current address 
register which holds the address used during 
transfers. Each channel can be programmed to 
increment or decrement this register whenever 
a transfer is completed. This register can be 
read or written by the CPU in consecutive 8-bit 
bytes. If autoinitialization 1s selected, this 
register will be reloaded from the base address 
register upon reaching terminal count in the 
current word count register. Channel 0 can be 
prevented from incrementing or decrementing 
by setting the address hold bit in the command 
register. 


Current Word Count Register 


Each channel has a current word count register 
which determines the number of transfers. The 
actual number of transfers performed will be 


one greater than the value programmed into the 
register. The register is decremented after each 
transfer until it goes from zero to FFFFH. When 
this roll-over occurs the UM82C206 will generate 
TC and either suspend operation on that 
channel and set the appropriate request mask 
bit or autoinitialize and continue. 


Base Address Register 


Associated with each Current Address Register 
is a Base Address Register. This is a write only 
register which is loaded by the CPU when 
writing to the Current Address Register. The 
purpose of this register 1s to store the initial 
value of the Current Address Register for 
autoinitialization. The contents of this register 
are loaded into the Current Address Register 
whenever terminal count is reached and the 
Autoinitialize Bit is set. 


Base Word Count Register 


This register preserves the initial value of the 
Current Word Count Register. It is also a write 
only register which is loaded by writing to the 
‘Current Word Count Register. This register 1s 
loaded into the Current Word Count Register 
during autoinitialization. 


Command Register 


This register controls the overall operation of a 
DMA subsystem. The register can be read or 
written by the CPU and is cleared by either 
RESET or a Master Clear command. 


Each DMA channel 


: Am 
== UM82C206 
Command Register Format ( Read/Write ) 
Bits Function 

7 DAK - Writing a "0" to this bit makes DACK an active low out- pin. Writing a "1" to this 
bit makes DACK an active high output pin. 

6 DRQ - Writing a "0" to this bit makes DREQ an active high input pin. Writing a “l" to 
this bit makes DREQ an active low input pin. 

5 EW - Writing a "l" to this bit enables Extended Write feature. It causes the write 
command to be asserted one DMA cycle earlier during a transfer. Thus read and write 
commands both begin in state S2 when enabled. 

4 RP - Writing a “l" to this bit selects a Rotating Priority scheme for honoring DMA 
requests. The default condition is fixed priority. 

3 CT - Writing a "l' to this bit enables the Compressed Timing. The default condition 
causes the DMA to operate with normal timing. 

2 CD - Controller Disable. Writing a “]" to this bit disables the DMA subsystem (DMA8 or 
DMA\16). This function is normally used whenever the CPU needs to reprogram one of 
the channels to prevent DMA cycles from occuring. 

] AH - Writing a "l" to these bit enables the address hold feature in Channel 0 when 
performing memory-to-memory transfer. 

0 M-M - Writing a "]" to this bit enables Channel 0 and Channel 1 to be used for memory-to 
memory transfers. 

Mode __ Register 


has a Mode Register can be read by sequentially reading the Mode 


associated with it. All four Mode Registers 
reside at the same I/O address. Bits 0 and 1 of 
the Write Mode Register command determine 
which channel Mode Register gets written. 
The remaining six bits control the mode of the 
selected channel. Each channel Mode Register 
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Register location. A Clear Mode register Counter 
command is provided to allow the CPU to 
restart the mode read process at a known point. 


During mode read operations, bit 0 and 1 will 
both be 1. 


iP vil UM82C206 


Bits 


7-6 


1-0 


Mode Register Format ( Read/Write ) 


Function 


These bits contain the information of mode selection for each channel : 


Function 


Mode Select 


Demand Mode 
Single Cycle Mode 

Block Mode 

Cascade Mode 

DEC - Writing a "1" to this bit DECrements the address after each transfer. 


Al - Writing a “1” to this bit enable Auto_Initialization function. 


These bits control the type of transfer which is to be performed. 


Function 


Transfer Type Select 


Verify Transfer 
Write Transfer 
Read Transfer 
Illegal 


These bits determine which channel's Mode Register will be written. Read back of a mode 
register will cause these bits to both be "1". 


Function 


Channel Selection 


esl Cat 


select Channel 0 
select Channel 1 
select Channel 2 
select Channel 3 


—reH CO © 
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Request Register 

This is a four bit register used to generate 
software requests (DMA _ service can_ be 
requested either externally or under software 
control). Request Register bits can be set or 
reset independently by the CPU. The Register 


Mask has no effect on software generated 
requests. All four bits are read in one operation, 
and appear in the lower four bits of the byte. 
Bits 4 through 7 are read as ones. All four 
request bits are cleared to zero by RESET. 


Request Register Write Format 


Bits Function 
7-3 Don't care. 
2 RB- Writing a "1" to this bit sets the Request Bit. 


1-0 RS1-RSO - Channel Request Select. These bits determine which channel's Request bit will be 
set. 


Function 


RS] RSO | Channel Selection 


0 0 select Channel 0 
0 ] select Channel 1] 
] 0 select Channel 2 
i 1] select Channel 3 
Request Register Read Format 
Bits Function 


7-4 Always reads "1". 


3-0 RC3-RCO - These bits contain the state of the request bit associated with each Request 
Channel. The bit position corresponds to the channel number. 
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Request Mask Register 

The Request mask register is a set of four bits 
which are used to inhibit external DMA 
requests from generating transfer cycles. This 
register can be programmed in two ways. Each 


channel can be independently masked by 
writing to the Write Single Mask Bit location. 
The data format for this operation is shown 
below. 


Request Mask Register Set/Reset Format 


Bits Function 


7-3 Don't care. 


2 MB: Writing a “1” to this bit set the request Mask Bit and inhibits external requests. 


1-0 MSI-MS0 - Channel request Mask Select. These bits determine which channel's Request 


Mask bit will be set. 


1 0 Function 

MS] MSO Channel Selection 
0 0 select Channel 0 
0 il select Channel 1 
i, 0 select Channel 2 
1 ] select Channel 3 


Alternatively all four mask bits can be 
programmed in one operation by writing to the 
Write All Mask Bits address. Data format for 


this and the Read All Mask Bits function is 
shown below. 


Request Mask Register Read/Write Format 


Bits Function 


7-4 Always reads "1". 


3-0 MB3-MB0 - These bits contain the state of the request Mask Bit associated with each 
request channel. The bit position corresponds to the channel number. 
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All four mask bits are set following a RESET or 
a Master Clear command. Individual channel 
mask bits will be set as a result of terminal 
count being reached, if autoinitialize is disabled. 
The entire register can be cleared, enabling all 
four channels by performing a Clear Mask 
Register operation. 


Status Register 


The status of all four channels can be 
determined by reading the Status Register. 
Information is available to determine if a 
channel has reached Terminal Count and 
whether an external service request is pending. 


Status Register Format ( Read ) 


Bits Function 


7-4 DRQ3-DRQ0 - These bits show the status of each channel request, and are not affected by 
the state of the Mask Register bits. Reading “l" means "request" occurs, and bits 7,6,5,4 
represent channels 3,2,1,0 respectively. These bits can be cleared by RESET, Master Clear or 


the pending request being deasserted. 


3-0 TC3-TCO - These bits indicate which channel has reached Terminal Count reading ‘1'. 
These bits can be cleared by RESET, Master Clear or each time a Status Read takes place. 
The channel number corresponds to the bit position. 


Temporary Register 


The Temporary Register is used as a temporary 
holding register for data during memory-to- 
memory transfers. The register is loaded during 


the first cycle of a memory-to-memory transfer 


from XD0-XD7. During the second cycle of the 
transfer,thedata in the Temporary Register is 
output on the XD0- XD7 pins. Data from the last 
memory-to-memory transfer will remain in the 
register. 


Special Commands 


Five Special Commands are provided to make 
the task of programming the device easier. 
These commands are activated as a result of a 
specific address and assertion of either a XIOR* 
or XIOW*. For these special commands, the data 


bus is ignored by the 82C206 whenever an 
XIOW* activated command is issued. Data 
returned on XIOR* activated commands is 
undefined. 


1. Clear Byte Pointer Flip-Flop - This command 
is normally executed prior to reading or 
writing to the address or word count 
registers. This initializes the flip-flop to point 
to the low byte of the register and allows the 
CPU to read or write the register bytes in 
correct sequence. 


2. Set Byte Pointer Flip-Flop - Setting the Byte 
Pointer Flip-Flop allows the CPU to adjust 
the pointer to the high byte of an address or 
word count register. 


3. Master Clear - This command has the same 
effect as a hardware RESET. The Command 
Register, Status Register, Request Register, 
Temporary Register, Mode Register counter 
and Byte pointer Flip-Flop are cleared and 
Request Mask Register is set. Immediately 
following Master Clear or RESET, the DMA 
will be in the Idle Condition. 


4. Clear Request Mask Register This 
command enables all four DMA channels to 
accept requests by clearing the mask bits in 
the register. 


5. Clear Mode Register Counter - In order to 
allow access to four Mode Registers while 
only using one address, an internal counter is 
used. After clearing the counter all four 
Mode Registers may be read by successive 
reads to the Mode Register. The order in 
which the registers will be read is Channel 0 
first, Channel 3 last. 


INTERRUPT SUBSYSTEM 


INTERRUPT CONTROLLLER FUNCTIONAL DESCRIPTION 


The programmable interrupt controllers in the 
UM82C206 function as a system wide interrupt 
manager in an iPAX86 system. They accept 
requests from peripherals, resolve priority on 
pending interrupts and interrupts in service, 
issue an interrupt request to the CPU, and 
provide a vector which is used as an index by 
the CPU to determine which interrupt service 
routine to execute. 

A variety of priority assignment modes are 
provided, which can be recofigured at any time 
during system operation, allowing the complete 


UM82C206 


interrupt subsystem to be restructured, based on 
the system environment. 


Overview 


Two interrupt controllers, INTC1 and INTC2, 
are included in the UM82C206. Each of the 
interrupt controllers is equivalent to an 8259A 
device operating in iPAX86 Mode. The two 
devices are interconnected and must be 
programmed to operate in Cascade Mode (see 
Figure 5) for proper operation of all 16 interrupt 


channels. INTCl is located at addresses 
020H-021H and is configured for Master 
operation (defined below) in Cascade 


Mode. INTC2 is a Slave device (defined below) 
and is located at OAOQH-OAIH. The Interrupt 
Request output signal from INTC2 (INT) ts 
internally connected to the interrupt request 
input Channel 2 (IR2) of INTCl. The address 
decoding and Cascade interconnection matches 
that of the IBM PC/AT. 

Two additional interconnections are made to 
the interrupt request inputs of the interrupt 
controllers. The output of Timer 0 in the 
Counter/Timer subsystem is connected to 
Channel 0 (IRO) of INTC1. Interrupt request 
from the Real Time Clock is connected to 
Channel 0 (IRO) of INTC2. Table 4 lists the 16 
interrupt channels and their interrupt request 
SOUICe. 


Description of the Interrupt Subsystem will 
pertain to both INTCI1 and INTC2 unless 
otherwise noted. Wherever register addresses 
are used, the address for the INTC1 register will 
be listed first and the address for the INTC2 
register will follow in parenthesis. Example 02H 
(OAOH). 
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Table 4. Interrupt Request Source 


: 
IR3 IRQ3 Input Pin 
IRS IRQ5 Input Pin 

: 
: 
: 


IRQ14 Input Pin 
IRQ15 Input Pin 


Controller Number 
INTC] 
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Controller Operation 


Figure 6 is a block diagram of the major 
elements in the controller. The Interrupt 
Request Register (IRR) is used to store requests 
from all of the channels which are requesting 
service. Interrupt Request Register bits are 
labeled using the Channel Name IR7-IRO. The 
In-Service Register (ISR) contains all the 
channels which are currently being serviced 
(more than one channel can be in service at a 
time). In-Service Register bits are labeled IS7-ISO 
and correspond to IR7-IRO. The Interrupt Mask 
Request (IMR)allows the CPU to disable any or 
all of the interrupt channels. The Priority 
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Resolver evaluates inputs from the above three 
registers, issues an interrupt request, and 
latches the corresponding bit into the In-Service 
Register. During interrupt acknowledge cycles, 
a master controller outputs a code to the slave 
device which is compared in the Cascade 
Buffer/ Comparator with a three bit ID code 
previously written. if a match occurs in the 
slave controller, it will generate an interrupt 
vector. The contents of the Vector Register are 
used to provide the CPU with an interrupt 
vector during Interrupt Acknowledge (INTA) 
cycles. 


IN-SERVICE 
REGISTER 


REQUEST 
REGISTER 
PRIORITY 


RESOLVER 


VECTOR 
DATA BUS 
REGISTER 
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Interrupt Sequence 


The UM82C206 allows the CPU to perform an 
indirect jump to a service routine in response to 
a request for service from a peripheral device. 
The indirect jump is based on a vector which is 
provided by the UM82C206 on the second of two 
CPU generated INTA cycles (the first INTA 
cycle is used for resolving priority and the 
second cycle is for transferring the vector to the 
CPU , see Figure 7). The events which occur 
during an interrupt sequence are as follows: 


1 - One or more of the interrupt requests 
(IR7-IRO) becomes active, the 
corresponding IRR bit(s). 


setting 


2 - The interrupt controller resolves priority 
based on the state of the IRR, IMR and ISR 
and asserts the INTR output if appropriate. 


3 - The CPU accepts the interrupt and responds 
with an INTA cycle. 


4 - During the first INTA cycle, the highest 
priority ISR bit is set and the corresponding 


on 


IRR bit is reset. The internal Cascade address 
iS generated. 


- The CPU will execute a second INTA cycle, 


during which the UM82C206 will drive an 
8-bit vector onto the data pins XD7-XD0, 
which is read by the CPU. The format of this 
vector 1s shown in Table 5. Note that V7-V3 in 
Table 5 are programmable by writing to 
Initialization Control Word 2 (see _ Initial- 
ization Command Words section below). 


- At the end of the second INTA cycle, the ISR 


bit will -be cleared if the Automatic End Of 
Interrupt mode is selected (see End Of 
Interrupt section below). Otherwise, the ISR 
bit must be cleared by an End Of Interrupt 
(EOI) command from the CPU at the end of 
the interrupt service routine to allows further 
interrupts. If no interrupt request is present 
at the beginning of the first INTA cycle (ie.a 
spurious interrupt), INTC1 will issue an 
interrupt level 7 vector during the second 
INTA cycle. 


INTERRUPT MUST REMAIN ACTIVE UNTIL 
THE FIRST INTA CYCLE BEGINS 


ee = Pe ip pee 


CASCADE PRIORITY RESOLVED 
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Figure 7. 
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End Of Interrupt 


EO! is defined as the condition which causes an 
ISR bit to be reset. Determination of which ISR 
bit is to be reset can be done by a CPU command 
(specific EOI) or, the Priority Resolver can be 
instructed to clear the highest priority ISR bit 
(non-specific EOI). The UM82C206 can determine 
the correct ISR bit to reset when operated in 
modes which do not alter the fully nested 
structure, since the current highest priority ISR 
bit 1S necessarily the last level acknowledged 
and serviced. In conditions where the fully 
nested structure 1s not preserved, a specific EOI 
must be generated at the end of the interrupt 
service routine. An ISR bit that is masked, in 
Special Mask Mode by an IMR bit, will not be 
cleared by a non- specific EOI command. The 
interrupt controller can optionally generate an 
Automatic End Of Interrupt (AEOI) on the 
trailing edge of the second INTA cycle. 


Priority Assignment 


Assignment of priority is based on an interrupt 
channel's position relative to the other channels 
in the interrupt controller. After the 
initialization sequence, IRO has the highest 
priority, IR7 the lowest, and priority assignment 
is fixed (Fixed Priority Mode). Priority 
assignment can be rotated either manually 
(Specific Rotation Mode) or automatically 
(Automatic Rotation Mode) by programming 
Operational Command Word 2 (OCW2). 


Fixed Priority Mode - This is the default 
condition which exists unless rotation (either 
manual or automatic) is enabled, or the 
controller is programmed for Polled Mode. In 
Fixed Priority Mode, interrupts are fully nested 
with priority assigned as shown: 


Lowest Highest 
PriorityStatus 7 6 5 4 3 2 1 0 
Nesting allows interrupts of a higher priority to 
generate interrupt requests prior to the 
completion of the interrupt in service. When an 


interrupt is acknowledged, priority is resolved, 
the highest priority request's vector is placed on 
the bus and the ISR bit for that channel is set. 
This bit remains set until an EOI (automatic or 
CPU generated) is issued to that channel. While 
the ISR bit is set, all interrupts of equal or lower 
priority are inhibited. Note that a_ higher 
priority service routine will only be 
acknowledged if the CPU has _ internally 


_ re-enabled interrupts. 


Specific Rotation Mode - Specific Rotatior 
allows the system software to re-assign priority 
levels by issuing a command which redefines 
the highest priority channel. 


Before Rotation 

Lowest Highest 
Priority Status (SS ots ee Sen 4 ea) 
(SPEcific Rotation command issued with 


Channel 5 specificed) 


After Rotation 


Lowest Highest 
Priority Status oF 4° 3. 224 6 
Automatic Rotation Mode - In applications 
where a number of equal priority peripherals 
are requesting interrupts, Automatic Rotation 
may be used to equalize the priority assignment. 
In this mode a peripheral, after being serviced, 
is assigned the lowest priority. All peripherals 
connected to the controller will be serviced at 
least once in 8 interrupt requests to the CPU 
from the controller. Automatic rotation will 
occur, if enabled, due to the occurrance of EOI 
(automatic or CPU generated). 


Before Rotation (IR3 is highest priority request 
being serviced) 
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ISR Status Bit —1S7 IS6 IS5 IS4 1S3 1S2 1S] ISO 


Pa 0 08 cle 200120 


Lowest Highest 


PriorityStatus 7 6 5 4 3 2 1 QO 


(SPEcific Rotation command 
Channel 4 specificed) 


issued with 


After Rotation 


ISR Status Bit IS7IS61S51S41S3 IS2 IS] ISO 
Ik 0.0 0.30 00 
Lowest Highest 


Erionity status. 93° 62 <1 O76 ~5 4 


Programming The Interrupt Controller 


Two type of commands are used to control the 
UM82C206 interrupt controllers, Initialization 
Command Words (ICWs) and Operational 
Command Words (OCWs). 


Initialization Command Words 


The initialization process consists of writing a 
sequence’'of 4 bytes to each interrupt controller. 
The initialization sequence is started by writing 
the first Initialization Command Word (ICW1) to 
address 020H (OA0H) with a 1 on bit 4 of the data 
byte. The interrupt controller interprets this as 


the start of an initialization sequence and docs 
the following: 


1 - The Initialization Command Word Counter is 
reset to zero. 


2 - ICW1 is latched into the device. 


3- Fixed Priority Mode 1s selected. 

4-1IR0O is assigned the highest priority. 

5 - The Interrupt Mask Register is cleared. 
6 - The Slave Mode Address is set to 7. 

7 - Special Mask Mode is disabled. 


8-The IRR 
operations. 


is selected for Status Read 


The next three I/O writes to address 021H 
(0A1H) will load ICW2-ICW4. See Figure 8 for a 
flow chart of the initialization sequence. The 
initialization sequence can be terminated at 
any point (all 4 bytes must be written for the 
controller to be properly initialized) by writing 
to address 02H( OAOH) with a 0 in data bit 4. Note, 
this will cause OCW2 or OCW3 to be written. 


Table 5. Interrupt Vector Byte 


Page a 


NO CASCADE 

MODE ? 
WRITE ICW3 

YES 


WRITE ICWL 
WRITE ICW2 


WRITE ICW4 


END OF INITIALIZATION 
CONTROLLER READY 


Initialization Sequence 
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ICW1 - Address 020H (0A0H) 


- Write Only 
Bits Function 
75 Don't care. 
4 Must set "1" for ICW1, Since ICW1, OC W2 and OCW3 share the same address,(020H, 0A0H). 
3 LTM - Bit 3 selects Level Triggered Mode or Edge triggered Mode input to the IR. If a ‘1" 


is written to LTM, a high level on the IR input will generate an interrupt request and the 
IR must be removed prior to EOI to prevent another interrupt. In Edge Triggered Mode, a 
low to high transition will generate an interrupt request. In either mode, IR must be held 
high until the first INTA cycle is started in order to generate the proper vector. I[R7 
vector will be generated if the IR input is deasserted early. 


2 Don't care. 


ah SM - This bit selects between Single Mode and Cascade Mode. Single Mode is used 
whenever only one interrupt controller (INTC1) is used and is not recommended for this 
device. Cascade Mode allows the two interrupt controllers to be connected through IR2 of 
INTC1. INTC1 will allow INTC2 to generate its own interrupt vectors if Cascade Mode is 
selected and the highest priority IR pending is from an INTC2 input. INTC1 and INTC2 
must be programmed for Cascade Mode for both devices to operate. 


0 Don't care. 


ICW2 - Address 021H (0A1H) 


- Write Only 
Bits Function 
7-3 V7-V3 - These bits are the upper 5 bits of the interrupt vector and are programmable by 


the CPU. INTC] and INTC2 need not be programmed with the same value in ICW2, usually 
INTC1 is programmed with a value of 08H ,and INTC2 is programmed with a value of 70H. 


2-0 The lower three bits of the vector are generated by the Priority Resolver during INTA 
(ses Table 5). 
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ICW3 - Format for INTC] - Address 021H 
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- Write Only 
Bits Function 
7-0 S7-S0 - Selects which IR inputs have Slave Mode controllers connected. ICW3 in INTCl 


must be written with a 04H(IRQ2) for INTC2 to function correctly. 


ICW3-Format for INTC1-Address 0A]H 


-Write Only 
Bits Function 
7-3 Don't care. 
2-0 [D2-IDO - Determines the Slave Mode address the controller will respond to during the 


cascade INTA sequence. ICW3 in INTC2 should be written with a 0O2H(IRQ2 of INTC1) for 
Cascade Mode operation. 


ICW4 - Address 021H (0A1H) 


- Write Only 
Bits Function 
7-5 Don't care. 
4 EMI - this bit will Enable Multiple Interrupts from the same channel in Fixed Priority 


Mode. This allows INTC2 to fully nest interrupts, when Cascade Mode with Fixed Priority 
Mode are both selected, without being blocked by INTC]. Correct handling of this mode 
requires the CPU to issue a non-specific EOI command to zero, when exiting an interrupt 
service routine. If zero, a non-specific EOI command should be sent to INTCI. If non-zero, 
no command is issued. 


3-2 Don't care. 


] AEOI - Auto End Of Interrupt is enabled when JCW4 is written with a one in bit 1. The 
interrupt controller will perform a non-specific EOI] on the trailing edge of the second 
INTA cycle. Note, this function should not be used in a device with fully nested interrupts 
unless the device 1s a cascade Master. 


0 Don't care. 
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Operational Command Words 

Operational Command Words (OCWs) allow the 
UM82C206 interrupt controllers to be controlled 
or reconfigured at any time while operating. 
Each interrupt has 3 OCWs which can be 
programmed to affect the proper operating 
configuration and a Status Register to monitor 
controller operation. 

Operational Command Word 1 (OCW1) 1s located 


OCW1 - Address 021H (OA1H) 
- Read/Write 


OCW2 - Address 020H (0A0H) 


at address 021H (OA1H) and may be written any 
time the controller is not in Initialization Mode. 
Operational Command Words 2 and 3 (OCW2, 
OCW3) are located at address 020H (0A0H). 
Writing to address 020H (OAOH) with a 0 in bit 4 
will place the controller in operational mode and 
load OCW2 (if data bit 3 = 0) or OCW3 (if data bit 
Sal) 


- Write Only 
Bits Function 
75 R,SL,EOI - These bits selects operational function. Writing a ‘l" in bit 7 causes one of the 


rotate functions to be selected. 


Writing a “l" in bit 6 causes a specific or immediate function to occur. All specific 
commands require L2-L0 to be valid except no operation. 
Writing a "1" in bit 5 causes a function related to EOI to occur. 


7 6 *) 
R SE EOI 
0 0 0 
0 0 1 
0 l 0 
0 ] 1 
] 0 0 
1 0 1 
1 1 0 
] i 1 


*12-L0 are used by these commands. 


Function 

operational function 

Clear rotate in auto EOI mode 
Non-specific EOI Command 

No operation 

Specific EO] Command * 

Set rotate 1n auto EOI mode 

Rotate on non-specific EO] Command 
Set priority Command * 


Rotate on specific EOI Command * 


4-3 These bits must be set "0" to indicate that OCW2 is selected, because ICW1, OCW2 and 
OCW3 share the same address, (020H, 0A0H). 


2-0 L2-LO - These three bits are internally decoded to select which interrupt channel is to be 
affected by the Specific command. L2-LO must be valid during three of the four specific 


cycles. 
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OCWS3 - Address 020H (OA0H) 


Bits 


1-0 


- Write Only 


Function 
This bit must be set "0". 


ESMM - Writing a 1 in this bit position Enables the set/reset Special Mask Mode Function 
controlled by bit 5 (SMM). ESMM allows the other functions in OCW3 to be accessed and 
manipulated without affecting the Special Mask Mode state. 

SMM - During Special Mask Mode, writing a 1 to any bit position of OCWI1 inhibits 
interrupts and a 0 enables interrupts on the associated channel by causing the Priority 
Resolver to ignore the condition of the JSR. 


6 5 Function 


ESMM SMM | Mask mode enable/select 


0 X No operation 
1 0 Reset special mask mode to normal mask mode 
1 1 Set special mask mode 


These bits must be set "0" to indicate that OCW3 is selected, because ICW1, OCW2 and 
OCW3 share the same address, (020H, 0A0H). 


PM - Writing a “1" to this bit of OCW3 enables Polled Mode. Writing OCW3 with poll mode 
acts like the first INTA cycle, freezing all interrupt request lines and resolving priority. 
The next read operation to the controller acts like a second INTA cycle and polled vector 
1s output to data bus. The format of polled vector is described later (see Poll Mode Read). 


RR - Writing a “l" to this bit enable the contents of IRR or ISR (determined by RIS) to be 
placed on XD7-XD0 when reading the Status Port at address 020H (OAOH). Asserting PM 
forces RR reset. 


1 0 Function 

RR RIS select next read register 
0 X No operation 

1 0 Read IRR on next read 
1 i Read ISR on next read 
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IRR, (SR and Poll Vector 


IRR, ISR and Poll Vector share the same address 
(020H, OAOH). The selection of the registers 
depends on the programming of ITC. If the 
latest OCW3 issued poll command, (PM=1), the 
poll vector is selected for the next read. Before 
another poll command js issued, subsequent read 


to the address will select IRR or ISR depending 
on the latest OCW3, if RR=1 and RIS=0, ISR is 
selected. Note that poll command is cleared after 
the first read to the ITC. After initialization 
(ICW1 or RESET), IRR is selected. 


IRR-Address 020H(0A0H) 
Bits Function 
7-0 IR7-IRO - These bits corresponds to the interrupt request bit of Interrupt Request Register. 


A “ton these bits indicate that an interrupt request is pending on the corresponding line. 


ISR-Address 020H(OA0H) 


Function 


will clear corresponding IS bit of ISR. 


IS7-ISO - These bits correspond to the interrupt service bit of Interrupt Service Register. A 
“l" on these bits indicate that an interrupt is being serviced on the corresponding line. EOI 


Poll Vector-Address 020H(0A0H) 


Bits Function 

7 INT - A “l" in these bits indicates that a pending interrupt is polled. If there is no pending 
interrupt request or the request is removed before the poll command, this bit is 0. 

6-3 Don't care. 

2-0 V2-V0 - These bits are the binary encoding of the highest priority level pending interrupt 


request being polled. If no pending interrupt has been polled, all three bits are equal to 1. 


Many registers share the same I/O address of 


INTC. The following table summarizes the address of each register. 


Register Selected 


es 


pp ICW2,ICW3,ICW4 during initialization sequence 
X X 


OCW1 (Mask Register) after initialization sequence 


6—40 


UM82C206 


COUNTER/ TIMER SUBSYSTEM 


COUNTER /TIMER 
FUNCTIONAL DESCRIPTION 


The UM82C206 contains a 8254 compatible 
counter /timer(CTC). The counter/ timer can be 
used to generate accurate time delays under 
software control. It contains 3 16-bit counters 
(counters 0-2) which can be programmed to 
count in binary or binary-coded decimal (BCD). 
Each counter operates inde- pendently of the 
other and can be programmed for operation asa 


TMRCLK 


CONTROL 


Ex CLK GATE 
OuT 


timer or a counter. 

All counters in this subsystem are controlled by 
a common control logic as shown in Figure 9. 
The control logic decodes and generates the 
necessary commands to load, read, configure 
and control each counter. Counter 0 and counter 
1 can be programmed for all six modes, but 
mode 1 and mode 5 have limited usefulness 
because their gate is hardwired to VCC 
internally. Counter 2 can be programmed to 
operate in any of the six modes as listed below: 


COUNTER O 


Vee 


TO IRGO 
CINTERNA@AL 
CONNECTION? 


COUNTER 1 


CLK GATE 


OUT ouTL 


COUNTER 2 


GATE2 
ouT2 


Figure 9. Counter/Timer Block Diagram 
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Mode 0 Interrupt on terminal count 
Mode 1 Hardware retriggerable one-shot 
Mode 2 Rate generator 

Mode 3 Square wave generator 

Mode 4 Software triggered strobe 

Mode 5 Hardware retriggerable strobe 


All three counters in this subsystem are driven 
from a common clock input pin (TMRCLK) 
which is different from other clock inputs to the 
UM82C206. Counter 0's output (OUTO) is 
internally connected to IRO of INTC] and may 
be used as an interrupt to the system for time 
keeping and task switching. Counter 1 may be 
programmed to generate pulses or square waves 
for external devices. Counter 2 is a full function 
counter/timer. It can be used as an interval 
timer, a counter, or as a gated rate/pulse 
generator. In PC/AT compatible design, counter 
0 is used as a System timer, counter 1 is used as a 
DRAM refresh rate generator, and counter 2 is 
used for speaker sound generation. 


Counter Description 


Each counter in this subsystem contains a 
control register, a status register, a 16-bit 
counting element, a pair of 8-bit counter input 
latchs, and a pair of 8-bit counter output latches. 
Each counter shares the same clock input 
(TMRCLK). GATE0,GATEI1 and OUTO are not 
externally accessible. This is fully compatible 
with PC/AT. Output of OUTO is dependent on 
the counter mode. (see Mode Definitions) 


The control 
command 


register stores the mode and 
information used to control the 
counter. It may be loaded by writing a byte to 
the write control word at port 043H. The status 
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register allows the software to monitor counter 
condition and read back the contents of the 
control register. 


The 16-bit counting element is a_ loadable 
synchronous down counter. It is loaded or 
decremented on the falling edge of TMRCLK. 
The counting element contains a maximum 
count when a 0 is loaded, which is equivalent to 
65536 in binary operation or 10000 in BCD. The 
counting element does not stop when it reaches 
0. In modes 2 and 3 the counting element will be 
reloaded and in all other modes it will wrap 
around to OFFFFH in binary operation or 9999 
in BCD. 


The counting element is indirectly loaded by 
writing one or two bytes (optional) to the 
counter input latches, which are in turn loaded 
into the counting element. Thus the counting 
element can be loaded or reloaded in one 
TMRCLK cycle. The counting element is also 
read indirectly by reading the contents of the 
counter output latches. The counter output 
latches are transparent latches which can be 
read while transparent or latched (see latch 
counter command). 


Programming The Counter! Timer 


After system reset the contents of control 
registers, Counter registers, counting elements, 
and the output of all counters are undefined. 
Each counter must be programmed before it can 
be used. Each counter is programmed by 
writing its control register with a control word 
and then giving an initial count to its counting 
element. Table 6 lists the I/O address map used 
by the counter/timer subsystem. 
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Table 6. Counter/Timer I/O Address Map 


Read/Write Counter Command 


Each counter has a write only control register. word to the I/O address 043H. The control word 
This control register is written with a control format is described here. 


Control Word Format (Write Only) 


Bits Function 
7-6 SC1-SCO - Select which counter this control word is written to. 
7 6 


SCl SCO Function 


0 0 select counter 0 
0 1 select counter 1 
1 0 select counter 2 
1 1 reserved for read-back command 
5-4 RW1-RWO - Determine the counter read/write word size. 
S 4 


RW1 RWO Function 


0 0 reserved for counter latch command 
0 1 read/write LSB only 
1 0 read/write MSB only 
1 ] read/write LSB first, then MSB 


MSB = most significant byte 
LSB = least significant byte 
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Bits Function 
an M2-M0 - Select the counter operating mode. 
Soe? oo 
M2 Ml MO Function 
O06 select mode 0 
O- 10" select mode 1 
X 1 O select mode 2 
» ae eae) | select mode 3 
10) st) select mode 4 
Db 30> at select mode 5 
0 BCD - During read/write counter commands control word writing, a “l" selects binary 


coded decimal counting format. A "0" selects binary counting format. During read-back 


command word writing, this bit must be 0. 


When programming to a counter, the below 
sequences must be followed: First, each counter's 
control register must be written with a control 
word before the initial count 1s written. Second, 
writing the initial count must follow the format 
specified in the control word (least significant 
byte only, most significant byte only, or least 
significant byte and then most significant byte). 
A new initial count can be written into the 
counter at any time after programming without 
rewriting the control word. 


Counter Latch Command 


When a counter latch command is issued, the 
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counter's output latches latch the current state 
of the counting element. The counter's output 
latches remain latched until read by the CPU or 
the counter is reprogrammed. After that the 
output latches then return to a "“transparent’ 
condition. Counter latch commands may be 
issued to more than one counter before reading 
the first counter to which this commannd was 
issued. Also, multiple counter latch commands 
issued to the same counter without reading the 
counter will cause all but the first command to 
be ignored. Below describes the counter latch 
command format. 


a 2 ther 
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Counter Latch Command Format (Write Only) 


Bits Function 
7-6 SC1-SC0 - Select which counter is being latched. 
ff 6 


SCl SCO Function 


0 0 select counter 0 

0 1 select counter 1 

l 0 select counter 2 

] 1 reserved for read-back command 
9-4 These two bits must be zero for the counter latch command. 
3-0 These four bits are don't care bits. 


Read-Back Command 


The read-back command allows the user to counter(s). The format of the _ read-back 
check the count value, mode, and state of the command is described below. 
OUT signal and null count flag of the selected 


Read-Back Command Format (Write Only) 


Bits Function 
7-6 These two bits must be "1" for the read-back command. 
5 LCOUNT - A "0" in this bit will latch the count of the counting element of the selected 
counter(s). 
4 LSTATUS- A "0" in this bit will latch the status information of the selected counter(s). 
3-1 C2-0 - These three bits select which counter(s) the read-back command is applied to. 
= e/a | 
C2 Ci C0 Function 


(Oaeaeey, Ses select counter 2 


X 0 xX select counter 1 


x X09 select counter 0 
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Each counter’s latches remain latched until 
either the latch is read or the counter is 
reprogrammed. If both LSTATUS and LCOUNT 
are "0", status will be returned on the next read 
from the counter. The next one or two reads (de- 
pending on whether the counter is programmed 


to transfer one or two bytes) from the counter 
result in the count being returned. Multiple 
read-back commands issued to the same counter 
without reading the counter will cause all but 
the first command to be ignored. The status 
read from each counter is described below. 


Status Format 


Bits Function 
7 OUT - This contains the state of the OUT signal of the counter. 
6 NC - This contains the condition of the null count flag. This flag is used to indicate that 


the contents of the counting element are valid. It will be set to a “1" during a write to the 
control register or the counter. It is cleared to a "0" whenever the counter is loaded from 
the counter input register. 


5-4 RW1-0 - These two bits indicate the counter read/write word size. This information is 
useful in determining where the high byte, the low byte or both must be transferred 
during counter read/write operations. 

3-] M2-0 - These bits reflect the operating mode of the counter and are interpreted in the same 
manner as in the write control word format. 

0 BCD - This bit indicates the counting element is operating in binary format or BCD format. 

Counter Operation 


Because counter 0 and counter 1 _ have 
limitations in some of their operating modes, we 
will use counter 2 to describe the various 
counter operating modes. But the description of 
modes 0, 2, 3 and 4 is suitable for all counters. 
The following terms are defined for describing 
counter /timer operation. 


TMRCLK pulse - A rising edge followed by a 
falling edge of the UM82C206 TMRCLK input. 


trigger - The rising edge of the GATE2 input. 


counter load - The transfer of the 16-bit value in 
counter input latches to to the counting element. 


initialized - A control word written and the 
counter input latches loaded. 


Counter 2 can operate in one of the following 
modes : 

Mode 0 - Interrupt on terminal count 

Mode 1 - Hardware retriggerable one-shot 

Mode 2 - Rate generator 

Mode 3 - Square wave generator 

Mode 4 - Software triggered strobe 

Mode 5 - Hardware triggered strobe 


6-46 


Mode 0 - Interrupt on terminal count 


Mode 0 is usually used for event counting. After 
the counter being written with the control word, 
OUT2 of the counter goes low and remains low 
until the counting element reaches 0 at which 
time it goes back high and remains high until a 
new count or control word 1s written. Counting 
is enabled when GATE2 = 1 and disabled when 
GATE2 = 0.GATEZ2 has no effect on OUT2. 


The counting element is loaded at the first 
TMRCLK pulse after the control word and 
initial count are loaded. When both initial count 
bytes are required, the counting element is 
loaded after the high byte is written. This 
TMRCLK pulse does not decrement the count, 
so for an initial count of N, OUT2 does not go 
high until N+l TMRCLK pulses _ after 
initialization. Writing a new initial count to the 
counter reloads the counting element on the 
next TMRCLK pulse and counting continues 
from the new count. If an initial count is written 
with GATEZ2 = 0, it will still be loaded on the 
next TMRCLK pulse. But counting does not 
progress until GATE2 = 1. When GATE2 goes 
high, OUT2 will go high after N TMRCLK 
pulses later. 


Mode 1 - Hardware retriggerable one-shot 


Writing the control word causes OUT2 to go 
high initially. Once initialized the counter is 
armed and a trigger causes OUT2 to go low on 
the next TMRCLK pulse. OUT2 then remains 
low until the counter reaches 0. An initial count 
of N results in a one-shot pulse N TMRCLK 
cycles long. Any subsequent triggers while 
OUTZ is low cause the counting element to be 
reloaded, extending the length of the pulse. 
Writing a new count to counter input latches 
will not affect the current one-shot pulse unless 
the counter is retriggered. In the latter case, the 
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counting element is loaded with the new count 
and the one-shot pulse continues until the new 
count expires. 


Mode 2 - Rate generator 


This mode functions as a divide-by-N counter. 
After writing the control word during 
initialization the counter's OUT2 1s set to high. 


When the initial count is decremented to 1, 
OUT2 goes low on the next TMRCLK pulse. The 
following TMRCLK pulse returns OUT2 high, 
reloads the CE and the process is repeated. In 
Mode 2 the counter continues counting (if 
GATE2 = 1) and will generate an OUT2 pulse 
every N TMRCLK cycles. Note that a count of 1 
is illegal in Mode 2. 

GATE2 = 0 disables counting and forces OUT2 
high immediately. A trigger reloads the CE on 
the next TMRCLK pulse. Thus GATE2 can be 
used to synchronize the counter to external 
events. 


Writing a new count while counting does not 
affect current operation unless a trigger is 
received. Otherwise, the new count will be 
loaded at the end of the current counting cycle. 


Mode 3 - Square wave generator 


Mode 3 is similar to Mode 2 in every respect 
except for the duty cycle of OUT2. OUT2 is set 
high initially and remains high for the first half 
of the count. When the first half of the initial 
count expires, OUT2 goes low for the remainder 
of the count. 

If the counter is loaded with an even count, the 
duty cycle of OUT2 will be 50% (high = low = 
N/2). For odd count values, OUT2 is high one 
TMRCLK cycle longer than it is low. Therefore, 
high = (N+1)/2 and low = (N-1)/2. 
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Mode 4 - Software triggered strobe 


Writing the Control Word causes OUTZ2 to go 
high initially. Expiration of the initial count 
causes OUT2 to go low for one TMRCLK cycle. 
GATE2 = 0 disables counting but has no effect 


on OUTZ2Z. Also, a trigger will not reload the CE. 


The counting sequence is started by writing the 
initial count. The CE is loaded on the TMRCLK 
pulse after initialization. The CE begins 
decrementing one TMRCLK pulse later OUT2 
will golow for one TMRCLK cycle, (N+1) cycles 
after the initial count is written. 


If a new initial count is written during a 
counting sequence, it is loaded into the CE on 
the next TMRCLK pulse and the sequence 
continues from the new count. This allows the 
sequence to be “retriggerable’ by software. 


Mode 5 - Hardware triggered strobe 


Writing the Control Word causes OUT2 to go 
high initially. Counting is started by trigger. 
The expiration of the initial count causes OUT2 
to go low for one TMRCLK cycle. GATE2 = 0 
disables counting. 


The CE is loaded on the TMRCLK pulse after a 
trigger. Since loading the CE _ inhibits 
decrementing, OUT2 will go low for one 
TMRCLK cycle, (N+1) TMRCLK cycles after the 
trigger. 


If a new count is loaded during counting, the 
current counting sequence will not be affected 
unless a trigger occurs. A trigger causes the 
counter to be reloaded from CIL and CIH, 
making the counter "retriggerable’. 


Table 7. Gate Pin Function 


Mode 


High 


Enables Counting 


a) Disables Counting 


Forces Out Pin High 


a) Disables Counting 


Initiates Counting 


b) Forces Out Pin High 


Initiates Counting 


Enables Counting 


Enables Counting 


Enables Counting 


Initiates Counting 
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In Modes 0,2,3 and 4 GATE2 is level sensitive 
and is sampled on the rising edge of TMRCLK. 
In Modes 1, 2,3 and 5 the GATEZ2 input is 
rising-edge sensitive. This rising edge sets an 
internal flip-flop whose output is sampled on the 
next rising edge of TMRCLK. The flip-flop 
resets immediately after being sampled. Note 
that in Modes 2 and 3 the GATE2 input is both 
edge and level sensitive. 


REAL TIME CLOCK SUBSYSTEM 


REAL TIME CLOCK 
FUNCTIONAL DESCRIPTION 


This subsystem of the UM82C206 integrates a 
complete time-of-day real time clock with alarm, 
one hundred year calendar, a programmable 
periodic interrupt, and 114 bytes of CMOS 
static RAM. The UM82C206 is designed to 
operate in a low power (battery powered) mode 
and protects the contents of both the CMOS 
static RAM and clock from change during 
system power up and down. 


Power-Up/Down 


Most applications will require the real time 
clock to remain active whenever the system 
power is turned off. To accomplish this the user 
must provide an alternate source of power to the 
UM82C206. This alternate source of power is 
normally provided by connecting a battery to 
the Vcc pin to switch from the system power 
supply to the battery. A circuit implementing 
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such a function is shown in Figure 10. It is used 
to eliminate power drain on the battery when 
the entire UM82C206 is active. It will also make 
a clean and reliable transition between system 
and battery power without drawing too much 
battery power. 


The PWRGD pin is provided on the device to 
protect the contents of RAM and the real time 
clock. It is also used to reduce power 
consumption whenevcr the system is powered 
down. This pin should be low whenever the 
system power supply is not within specifications 
for proper operation of the system. This pin may 
be driven by circuitry in either the power 
supply or on the system board. When the 
PWRGD input is low, it will disable all un- 
necessary inputs and outputs. In this way it will 
prevent noise on the inactive pins and reduce 
leakage current when the system is powered 
down. This pin must therefore be at high level 
for the remainder of the device to operate 
properly when system power 1s applied. 


The PSRSTB* pin is provided to initialize the 
device whenever power is applied to the 
UM82C206. This pin will not alter the RAM or 
real time clock contents but it will initialize the 
necessary control register bits. A low on 
PSRSTB* pin disables the generation of 
interrupts and sets a flag indicating that the 
contents of the device may not be valid. A 
recommended circuit for controlling the 
PSRSTB* input is shown in Figure 10. 
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Register Access 


Reading and writing to the 128 locations in this 
subsystem is accomplished by first placing the 
index address of the location you wish to access 
on the data input pins XD0-XD6 and then 
strobing the AS input pin. The address will then 
be latched into the index address register on the 
falling edge of AS. The index address register is 


then used as a pointer to the specific byte in this 
subsystem, which may be read or written by 


asserting XIOR* or XIOW* with an address of 
071H on the XA9-XA0 input pins. 


In PC/AT compatible design, the AS is 
generated by an I/O write operation to port 
070H. To avoid the unintentional change of the 
contents of real time clock and CMOS RAM, it is 
recommended that an address of 070H be ap- 
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CSYSTEM 
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and Reset Clrcultry 


plied to the XA9-XA0 inputs of UM82C206 
during the AS asserted time. 


Address Map 


Table 8 illustrates the internal register/RAM 
organization of the real time clock subsystem of 
the UM82C206. The 128 addressable locations in 
this subsystem are divided into 10 bytes which 
normally contain the time, calendar, alarm 
setting and four control and status bytes and 
114 general purpose CMOS RAM bytes. All 128 
bytes are readable by the CPU. The CPU may 
also write to all locations except registers 0CH, 
ODH, bit 7 of register OAH and bit 7 of the 
register 00H which is always 0. 
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Time/Calender and Alarm Bytes 


The CPU can obtain the time and calendar 
information by reading the appropriate 
locations in the real time clock. Initialization of 
the time, calendar and alarm information is 
accomplished by writing to these bytes. Data 
stored in these locations are in binary-coded 
decimal (BCD) format. 

Before initialization of the internal registers of 


the real time clock, the SET bit in register OBH 
should be set to a "1" to prevent real time clock 
from updating. The CPU then initializes the 
first 10 locations in BCD format. The SET bit 
should then be cleared to allow updating. After 
initialized and enabled, the real time clock will 
perform clock/calendar updates at a 1.024 KHz 
rate in PC/AT compatible design. 


Table 9. Time, Calendar, Alarm Data Format 
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Address 
a 
ae ae ao 


Hours 
(12 hour mode) 


Hours 
(24 hour mode) 


Hours of Alarm 
(12 hour mode) 


Hours of Alarm 
(24 hour mode) 


a 
a 


01-12 (AM) 
81-92 (PM) 


01-12 (AM) 
81-92 (PM) 


01-12 


00-99 
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The alarm bytes can be programmed to 
generate an interrupt at a specific time or they 
can be programmed to generate a_ periodic 
interrupt. To generate an interrupt at a specific 
time, the user need only program the time that 
the interrupt is to occur into the 3 alarm bytes. 
Alternately, a periodic interrupt can be 
generated by setting the high order two bits in 
an alarm register to a ‘l", which turns that byte 
into a "don't care". For instance, an interrupt can 
be generated once a second by programming the 
same value into all three alarm registers. 


Table 9 shows the format for the ten clock, 
calendar and alarm registers. The 24/12 bit in 
Register OBH determines whether the hour 
locations will be updated using a 1-12 or 0-23 
format. After initialization the 24/12 bit cannot 
be changed without reinitializing the hour 
locations. In 12 hour format the bit 7 of the 
hours byte in both the time and alarm bytes will 


UIP BIT 
CREGISTER Ad 


UPDATE CYCLE 
ACTIVE PERIOD 


UF BIT 
CREGISTER CC) 


NOTE: 


indicate PM when it isa “1". 


Update Cycle 


During normal operation the real time clock 
will perform an update cycle, assuming one of 
the proper time bases is chosen, the divider bits 
DV2-DV0 isn't reset and the SET bit in register 
OBH is cleared. The function of the update cycle 
is to increment the clock/calendar registers and 
compare them to the alarm registers. If a match 
or don't care condition occurs between the two 
sets of registers, an alarm is issued and an 
interrupt control bits are enabled. 


During an update cycle, the lower 10 registers 
are not accessible by the CPU. By this way it 
can prevent the possible corruption of data in 
the real time clock registers or the reading of 
incorrect data. To avoid contention between the 


a SEE NOTE 1 


SEE NOTE 2 


1. REGISTER O-9 ARE UNAVAILABLE FOR READ OR WRITE 


THIS TIME. 


2. UF BIT CLEARED BY READING REGISTER C. 


Polequugme- cei. 
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Update Cycle 


real time clock and the CPU, a flag is provided 
in register OAH to alert the user of an update in 
progress cycle. This update in progress bit (UIP) 
is asserted 244us before the actual start of the 
cycle and is maintained until the cycle is 
complete. Once the cycle is complete the UIP bit 
will be cleared and the update flag (UF) in 
register OCH will be set. Figure 11 illustrates the 
update cycle. CPU access is always allowed to 
registers OAH through ODH during update 
cycles. 


Two recommended methods can be used for 
reading and writing to the real time clock ina 
PC/AT compatible design. Both of them will 
allow the user to avoid contention between the 
CPU and the real time clock for access to the 
time and date data. 


The first method is to read register OAH, 
determine the state of the UIP bit and if it is 0’, 
perform the read or write operation. For this 
method to work successfully the entire read or 
write operation (including any interrupt service 
routines which might occur) must not require 
longer than 244us to complete from the 
beginning of the read of register OAH to the 
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completion of the last read or write operation to 
the clock calendar registers. 


The second method of accessing the lower 10 
registers is to read register OCH once and 
disregard the contents. Then subsequently 
continue reading this register until the UF bit is 
a "l". This bit will become true immediately 
after an update cycle has been completed. The 
user then has to complete a read or write 
operation before the next update cycle. 


Control and Status Registers 


The UM82C206 contains four registers used to 
control the operation and monitor the status of 
the real time clock. The CPU can access these 
registers at any time with index address at 
OAH-ODH. 


REGISTER OAH 


Index register port : 70H 
Data register port : 71H 
Index :0AH (Read/Write register except UIP) 


REGISTER 0AH 


Bits Function 


vf UIP - Update in progress flag is a status bit used to indicate when an update cycle is about 
to take place. A "1" indicates that an update cycle is taking place or is imminent. UIP will 
go active (HIGH) 244us prior to the start of an update cycle and will remain active for an 
additional 2ms while the update is occurring. The UIP bit is read only and is not affected 
by reset. Writing a "l" to the SET bit in register OBH will clear the UIP status bit. 


6-4 DV2-DV0 - These three bits are used to control the Divider/Prescaler on the real time 
clock. While the UM82C206 can operate at frequencies higher than 32.768 KHz, this is not 
recommended for battery powered operation due to the increased power consumption at 


these higher frequencies. 
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Bits Function 
6 5 4 Divider Options 
DV2 DVl DVO Mode 
1 1 X Reset Divider 
3-0 RS3-RSO - These four bits control the periodic interrupt rate. The periodic interrupt is 


derived from the divider/prescaler in the real time clock and is separated from the alarm 
interrupt. Both the alarm and periodic interrupts do, however, use the same interrupt 
channel in the interrupt controller. Use of the periodic interrupt allows the generation of 
interrupts at rates higher than once per second. Below are the interrupt rates for which 
the real time clock can be programmed. 

Sia cee 10) Periodic Interrupt Rate 


4194304MHz time base 
RS3 RS2 RS] RSO 1.048576MHz time base 32.768KHz time base 


0 0 0 90 None None 
0 Jj 30517 us 390625 ms 
0 61.035 us 78125 ms 


fe i |= | =) 
— 


— 
S 
oS 
© 


1 1] 122.070 us 122.070 us 
Jette M9) 244141 us 244141 us 


o;}o ;}o;o|]o 


Oe 21 488281 us 488281 us 
Uae eee ea) 976.562 us 976.562 us 
ee eo el 1953125 ms 1.953125 ms 
3.90625 ms 390625 ms 

O- 0: A 78125 ms 78125 ms 

ee (ares GO 0 15625 ms 15.625 ms 
0 1 31.25 ms 31.25 ms 
Lon ] 625 ms 625 ms 
eee Ua 8 ia 125 ms 125 ms 
ie el eal ea) 250 ms 250 ms 
000 ms 


6 


| 
on 
Z)) 


Oume UM82C206 


REGISTER OBH 


Index register port : 70H 
Data register port : 71H 
Index :0BH (Read/Write register) 


Bits Function 


7 SET - Writing a "0" to this bit enables the Update Cycle and allows the Real Time Clock to 
function normally. When set to a “l" the Update Cycle is inhibited and any cycle in 
progress is aborted. The SET bit is not affected by the RESET input pin. 


6 PIE - The Periodic Interrupt Enable Bit controls the generation of interrupts based on the 
value programmed into the RS3-RSO bits of Register OAH. This allows the user to disable 
this function without affecting the programmed rate. Writing a "1" to this bit enables the 
generation of periodic interrupts. This bit is cleared to '( by Reset. 


5 AIE - The generation of alarm interrupts is enabled by setting this bit to a ‘l". Once this 
bit is enabled the Real Time Clock will generate an alarm whenever a match occurs 
between the programmed alarm and clock information. If the don't care condition is pro- 
grammed into one or more of the Alarm Registers, this will enable the generation of 
periodic interrupts at rates of one second or greater. This bit is cleared by Reset. 


4 UIE - The update ended interrupt enable bit is used to enable the update end fiag (UF) bit 
in register OCH to generate an interrupt. A “l" in this bit enables the interrupt generating. 
A "0" disables it. This bit is cleared by reset. It is also cleared when the SET bit goes high. 


3 SQWE - The square wave enable bit is always fixed to 0. It will disable the square wave 
generation. 

2 DM - The data mode bit is always fixed to 0. It will always select the BCD format for real 
time clock. 

1 24/12 - The 24/12 control bit is used to establish the format of both the Hour and Hour 


Alarm bytes. If this bit is a “l", the Real Time Clock will interpret and update the 
information in these two bytes using the 24 hour mode. This bit can be read or written by 
the CPU and is not affected by Reset. 


0 DSE - The Real Time Clock can be instructed to handle daylight savings time changes by 
setting this bit to a “l". This enables two execeptions to the normal time keeping sequence 
to occur. On the first Sunday in April the time increments from 1:59:59 AM to 3:00:00 AM. 
On the last sunday in October when the time first reaches 1:59:59 AM it changes to 1:00:00 
AM. Setting this bit to a "0" disables the execution of these two exceptions. RESET has no 
effet on this bit. 
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REGISTER 0CH 


Index register port : 70H 
Data register port : 71H 


Bits 


oa! 


3-0 


Function 


IRQF - The interrupt request flag bit is set toa "1" when any of the conditions which can 
cause an interrupt is true and the interrupt enable for that condition is true. The condition 
which causes this bit to be set, also generates an interrupt. The logic expression for this 
flag is: 

IRQF = PF & PIE+ AF & AIE+ UF & UIE 
This bit and all other active bits in this register are cleared by reading the register or by 
activating the PSRSTB? input pin. Writing to this register has no effect on the contents. 


PF - The periodic interrupt flag is set to a "]" when a transition, which is selected by 
RS3-RSO, occurs in the divider chain. This bit will become active, independent of the 
condition of the PIE control bit. The PF bit will then generate an interrupt and set IRQF if 
PIE isa ‘)". 


AF - Al" appears in the AF bit whenever a match has occured between the time registers 
and alarm registers during an update cycle. This flag is also independent of it's enable 


(AIE) and will generate an interrupt if AIE is true. 


UF - A "l" appears in the UF bit whenever an update cycle is ended. This flag is also 
independent of it's enable (UIE) and will generate an interrupt if UIE ts true. 


Not used - All unused bits will be "0" when read and are not writeable. 


REGISTER ODH 


Index register port : 70H 
Data register port : 711] 
Index :0DH (Read Only register) 


Bits 


6-0 


Function 


VRT - The valid CMOS RAM and time bit indicates the condition of the contents of the 
RAM and real time clock. This bit 1s cleared to a '0" whenever the PSRSTB* input pin is 
low. This is normally derived from the power supply which supplies Vcc to the device and 
will allow the user to determine whether the registers have been initialized since power 
was applied to the device. Reset has no effect on this bit and it can only be set by reading 
register ODH. 


Not used - All unused bits will be "0" when read and are not writeable. 
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CMOS Static RAM 


The 114 bytes of RAM from index address 0EH 
to 7FH are not affected by the real time clock. 
They are accessible during the update cycle and 
may be used for whatever the designer wishes. 


Typices: anpolications will use these as 
nonvolatile storage for system configuration 
parameters. They are normally battery powered 
when the system is turned off. 


ABSOLUTE MAXIMUM RATINGS*® 


Parameter Symbol Min. Max. Unit 
Supply Voltage VCC 03 +67 V 
Input Voltage Vi 03 +6.7 V 
Output Voltage Vo 03 Vcect03 V 
Operating Temperature Top 20 +70 CC 
Storage Temperature Tstg cs +125 c 


“Comments 


Stresses above those listed under “Absolute 
Maximum Ratings" may cause permanent 
damage to the device. These are a stress ratings 
only and functional operation of the device at 


these or any other conditions above those 
indicated in the operational sections of this 
specification 1s not implied. 


DC ELECTRICAL CHARACTERISTICS 
(Vcc = 4.75 to 525V, Ta = -20 to +70 C) 


bl ens val 2 inal 
Condition 
Ce eee 
i a 
a fasnnvaoriemn | —[™ [| 
por fv] [fe 
ee 


Iccsb Standby Power Supply Current SCs (eee: aoe 


_—_ High Voltage 


[Input Leakage Current | Leakage Current 
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AC ELECTRICAL CHARACTERISTICS (8 MHz) 
(Vcc = 475 to 525V, Ta = -20 to +70 C) 


Symbol} Description Min. Typ. Max. | Unit Test Note 
Condition 
ga 


Address hold time from command mn "2 FG : 
inactive 

Ca 
[a ahem fo | | fe [| 
fe pommel | fe [» | | 
a a 
[o_fstotiimnormane|e | | [= | | 
[= fone fm | | fm» | | 
To renown pe T | f=» | | 
ee 
fo foeomeow || f= [= | 
a 
a fsnienn i> | |e | | 
[ae _psasmcwismee fe | |» || 
[_postsonctensnane fe | |» | | 
[en focs— | Tm | 
psn fo 
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a 
Ne oe 


TMRCLK low time 
t42 TMRCLK high time 


OUT2 delay from TMRCLK 120 
OUT2 delay from GATE2 Ls 120 


SYSCLK period (DMA clock = 
SYSCLK) 


ad 


g 
eV) 


SYSCLK period 
SYSCLK/2) 


(DMA clock 


SYSCLK low time (DMA clock 
SYSCLK) 


t5la SYSCLK low time (DMA clock = 


SY OCIEK 2) 


ce 
on 
i) 


SYSCLK high time (DMA clock 
SYSCLK) 


t52a SYSCLK high time (DMA clock 


SYSCLK/2) 


mmonnsnex > | |_|» || 
monwrmsnax | | |e |» || 


t53 
t54 
t55 


HLDAI setup to SYSCLK ins 
t56 AENi valid delay from SYSCLK Qn ae 
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Condition 
Po fevmaoemene | | fm ie | | 
Pe hsramnemrensax | | fe [= | | 
ee 
ioxraaawreonsrcex| | fa fe | | _ 
: 


XD0-XD7 tristate delay from SYSCLK 


Address valid delay from SYSCLK 


Address hold time from DMAMEMR 
high 


t 
t 
t 


a 


60 
61 
62 
t63 
t64 
t65 


00 


t 


Address tristate delay from SYSCLK 
DACKi delay from SYSCLK 
Command enable delay from SYSCLK 


Command active delay from SYSCLK 


66 
t67 
t68 
t69 


t70 Write command inactive delay from 
SYSCLK 


t71 Address hold time from write|75 
command high 

t72 Command tristate delay from 9) 
SYSCLK 

t73 Read command inactive delay from 


115 
SYSCLK TC delay from SYSCLK sa 
TC delay from SYSCLK , | 


XD0-XD7 setup to read command 
inactive 


t74 
79 


t 


~) ens on 
bo oS On 
—) o1 


6-61 


UM82C206 


XD0-XD7 hold 
command inactive 


oa comer | | p= = || 


XD0-XD7 hold from write command] 15 
inactive 
fo fesse fe ||» | | 


time from 


SYSCLK 
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DMA Transfer Timing 
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see note 1 
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Compressed Transfer 


NOTES : 


1. All timings referenced to SCLK are 
independent of the state of the clock select 
bit in the configuration register. SCLK shown 
in this diagram is the undivided clock 
directly from the input. 


2.Extended Write mode selected. 


3, Extended Read mode selected. 
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4. IOCHRDY Input Timing. 


5. DMA wait states are added between S$3,S4 in 


normal timing; between S2,S4 in compressed 
timing; between S13, S14 and S23, $24 in 
memory-to-memory timing. 


